package cn.com.blueInfo.bpm.system.service;

import cn.com.blueInfo.bpm.system.request.DynamicFormFieldDTO;
import cn.com.blueInfo.bpm.system.response.DynamicFormFieldVO;
import cn.com.blueInfo.utils.result.ResultInfo;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;

import java.util.List;

/**
 * 动态表单字段 业务服务类
 * @author suxch
 * @since 2025-08-24 01:37:55
 */
public interface DynamicFormFieldService {

    /**
     * 新增动态表单字段
     * @param dynamicFormFieldDTO 动态表单字段参数
     */
    ResultInfo<Integer> addDynamicFormField(DynamicFormFieldDTO dynamicFormFieldDTO);

    /**
     * 批量新增动态表单字段
     * @param dynamicFormFieldDTOList 动态表单字段参数列表
     */
    ResultInfo<Integer> batchAddDynamicFormField(List<DynamicFormFieldDTO> dynamicFormFieldDTOList);

    /**
     * 删除动态表单字段
     * @param dynamicFormFieldId 动态表单字段ID
     */
    ResultInfo<Integer> removeDynamicFormField(Long dynamicFormFieldId);

    /**
     * 批量删除动态表单字段
     * @param dynamicFormFieldIdList 动态表单字段ID列表
     */
    ResultInfo<Integer> batchRemoveDynamicFormField(List<Long> dynamicFormFieldIdList);

    /**
     * 更新部分动态表单字段
     * @param dynamicFormFieldUpdatePartialDTO 动态表单字段参数
     */
    ResultInfo<Integer> modifyDynamicFormFieldPartial(
            DynamicFormFieldDTO.UpdatePartialDTO dynamicFormFieldUpdatePartialDTO);

    /**
     * 更新全部动态表单字段
     * @param dynamicFormFieldDTO 动态表单字段参数
     */
    ResultInfo<Integer> modifyDynamicFormField(DynamicFormFieldDTO dynamicFormFieldDTO);

    /**
     * 查询一条动态表单字段
     * @param dynamicFormFieldId 动态表单字段ID
     */
    ResultInfo<DynamicFormFieldVO> queryDynamicFormFieldById(Long dynamicFormFieldId);

    /**
     * 分页查询动态表单字段
     * @param dynamicFormFieldQueryDTO 动态表单字段参数
     */
    ResultInfo<Page<DynamicFormFieldVO>> queryDynamicFormFieldPage(
            DynamicFormFieldDTO.QueryDTO dynamicFormFieldQueryDTO);

    /**
     * 根据条件查询 动态表单字段 数量
     * @param dynamicFormFieldQueryDTO 动态表单字段参数
     */
    ResultInfo<Long> queryDynamicFormFieldCount(DynamicFormFieldDTO.QueryDTO dynamicFormFieldQueryDTO);

    /**
     * 根据条件查询 动态表单字段
     * @param dynamicFormFieldQueryDTO 动态表单字段参数
     */
    ResultInfo<List<DynamicFormFieldVO>> queryDynamicFormFieldList(
            DynamicFormFieldDTO.QueryDTO dynamicFormFieldQueryDTO);

}
